package com.hjr.leetcode.question100;

import java.util.Arrays;

/**
 *26. 删除有序数组中的重复项
 * 给你一个 非严格递增排列 的数组 nums ，请你 原地 删除重复出现的元素，使每个元素 只出现一次 ，返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。
 *
 * 考虑 nums 的唯一元素的数量为 k ，你需要做以下事情确保你的题解可以被通过：
 *
 * 更改数组 nums ，使 nums 的前 k 个元素包含唯一元素，并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
 * 返回 k 。
 */
public class q26 {

    public static void main(String[] args) {
        int[] nums = {1, 1, 2};
        System.out.println(removeDuplicates(nums));
        for (int num : nums) {
            System.out.println(num);
        }
    }

    //双指针
    public static int removeDuplicates(int[] nums) {
        int l = 0, r = l + 1;
        int length = nums.length;
        while (l < r && r < length){
            if (nums[l] == nums[r]){
                while (r + 1 < length){
                    nums[r] = nums[r + 1];
                    r++;
                }
                r = l + 1;
                length--;
            }else {
                l++;
                r++;
            }
        }
        return r;
    }
}
